New visibility handling in gdk
authorMatthias Clasen <mclasen@redhat.com>
Fri, 15 Mar 2013 10:35:30 +0000 (06:35 -0400)
committerMatthias Clasen <mclasen@redhat.com>
Sun, 5 May 2013 19:38:48 +0000 (15:38 -0400)
Change the visibility handling to be the same way we do it in
GLib now. We pass -fvisibility=hidden to gcc and decorate public
functions with __attribute__((visibility("default"))).

This commit just does this for GDK, GTK+ will follow later.

configure.ac
gdk/Makefile.am
gdk/broadway/Makefile.am
gdk/quartz/Makefile.am
gdk/wayland/Makefile.am
gdk/win32/Makefile.am
gdk/x11/Makefile.am

index d15fdbd1de2003e8cc95d671c31dcf1726999380..cb522617e20aae0d2bee871209ada24f317defd5 100644 (file)
@@ -1673,6 +1673,39 @@ else
   AC_MSG_RESULT([no])
 fi
 
+##################################################
+# Visibility handling
+##################################################
+
+GDK_HIDDEN_VISIBILITY_CFLAGS=""
+case "$host" in
+  *-*-mingw*)
+    dnl on mingw32 we do -fvisibility=hidden and __declspec(dllexport)
+    AC_DEFINE([_GDK_EXTERN], [__attribute__((visibility("default"))) __declspec(dllexport) extern],
+              [defines how to decorate public symbols while building])
+    CFLAGS="${CFLAGS} -fvisibility=hidden"
+    ;;
+  *)
+    dnl on other compilers, check if we can do -fvisibility=hidden
+    SAVED_CFLAGS="${CFLAGS}"
+    CFLAGS="-fvisibility=hidden"
+    AC_MSG_CHECKING([for -fvisibility=hidden compiler flag])
+    AC_TRY_COMPILE([], [int main (void) { return 0; }],
+                   AC_MSG_RESULT(yes)
+                   enable_fvisibility_hidden=yes,
+                   AC_MSG_RESULT(no)
+                   enable_fvisibility_hidden=no)
+    CFLAGS="${SAVED_CFLAGS}"
+
+    AS_IF([test "${enable_fvisibility_hidden}" = "yes"], [
+      AC_DEFINE([_GDK_EXTERN], [__attribute__((visibility("default"))) extern],
+                [defines how to decorate public symbols while building])
+      GDK_HIDDEN_VISIBILITY_CFLAGS="-fvisibility=hidden"
+    ])
+    ;;
+esac
+AC_SUBST(GDK_HIDDEN_VISIBILITY_CFLAGS)
+
 ##################################################
 # Output commands
 ##################################################
index 0b81376af1ef1bd837e881725dc51c0a242eb661..161996f16b590c26f3dd0a03123a68ef8809a536 100644 (file)
@@ -144,11 +144,11 @@ gdk_c_sources =                           \
        gdkwindowimpl.c
 
 gdk_built_sources =                            \
+       gdkenumtypes.h                          \
        gdkenumtypes.c                          \
        gdkmarshalers.h                         \
        gdkmarshalers.c                         \
-       gdkversionmacros.h                      \
-       gdkenumtypes.h
+       gdkversionmacros.h
 
 #
 # setup GDK sources and their dependencies
@@ -166,6 +166,7 @@ common_sources =            \
        gdkmarshalers.h
 
 libgdk_3_la_SOURCES = $(common_sources)
+libgdk_3_la_CFLAGS = $(AM_CFLAGS) $(GDK_HIDDEN_VISIBILITY_CFLAGS)
 libgdk_3_la_LIBADD = $(GDK_DEP_LIBS)
 libgdk_3_la_LDFLAGS = $(LDADD)
 
index 661fb7e4a8b66d5fc152b3188931ba3f1effdb8c..1bbde7c31225869a805d3feedb02b394b88e0e8a 100644 (file)
@@ -4,13 +4,14 @@ include $(top_srcdir)/Makefile.decl
 libgdkincludedir = $(includedir)/gtk-3.0/gdk
 libgdkbroadwayincludedir = $(includedir)/gtk-3.0/gdk/broadway
 
-AM_CPPFLAGS =                  \
-       -DG_LOG_DOMAIN=\"Gdk\"  \
-       -DGDK_COMPILATION       \
-       -I$(top_srcdir)         \
-       -I$(top_srcdir)/gdk     \
-       -I$(top_builddir)/gdk   \
-       $(GTK_DEBUG_FLAGS)      \
+AM_CPPFLAGS =                          \
+       -DG_LOG_DOMAIN=\"Gdk\"          \
+       -DGDK_COMPILATION               \
+       -I$(top_srcdir)                 \
+       -I$(top_srcdir)/gdk             \
+       -I$(top_builddir)/gdk           \
+       $(GDK_HIDDEN_VISIBILITY_CFLAGS) \
+       $(GTK_DEBUG_FLAGS)              \
        $(GDK_DEP_CFLAGS)
 
 LDADDS = $(GDK_DEP_LIBS)
index a8be38e4f8103ace15c7f8cc708a9c52c150c4f9..2c8fb90e6aa2be03315ae641354f66ba82f8112f 100644 (file)
@@ -9,6 +9,7 @@ AM_CPPFLAGS =                           \
        -I$(top_srcdir)                 \
        -I$(top_srcdir)/gdk             \
        -I$(top_builddir)/gdk           \
+       $(GDK_HIDDEN_VISIBILITY_CFLAGS) \
        $(GTK_DEBUG_FLAGS)              \
        $(GDK_DEP_CFLAGS)               \
        "-xobjective-c"
index 5b66090b04aafe130fc47ee1ec61c627e2de040e..eed33ad2a541def12193a215ff181ecb59298b37 100644 (file)
@@ -10,6 +10,7 @@ AM_CPPFLAGS =                                 \
        -I$(top_srcdir)                         \
        -I$(top_srcdir)/gdk                     \
        -I$(top_builddir)/gdk                   \
+       $(GDK_HIDDEN_VISIBILITY_CFLAGS)         \
        $(GTK_DEBUG_FLAGS)                      \
        $(GDK_DEP_CFLAGS)
 
index 492e1c55d93df44b638c2eea0da7edbae64f1164..ef5f6e88518394f89738f34d6222f8b572c81943 100644 (file)
@@ -5,14 +5,15 @@ libgdkincludedir = $(includedir)/gtk-3.0/gdk
 libgdkwin32includedir = $(includedir)/gtk-3.0/gdk/win32
 
 AM_CPPFLAGS = \
-       -DG_LOG_DOMAIN=\"Gdk\"  \
-       -DINSIDE_GDK_WIN32      \
-       -I$(top_srcdir)         \
-       -I$(top_srcdir)/gdk     \
-       -I$(top_builddir)/gdk   \
-       $(GTK_DEBUG_FLAGS)      \
-       $(GDK_DEP_CFLAGS)       \
-       $(GDK_WIN32_EXTRA_CFLAGS)\
+       -DG_LOG_DOMAIN=\"Gdk\"          \
+       -DINSIDE_GDK_WIN32              \
+       -I$(top_srcdir)                 \
+       -I$(top_srcdir)/gdk             \
+       -I$(top_builddir)/gdk           \
+       $(GDK_HIDDEN_VISIBILITY_CFLAGS) \
+       $(GTK_DEBUG_FLAGS)              \
+       $(GDK_DEP_CFLAGS)               \
+       $(GDK_WIN32_EXTRA_CFLAGS)       \
        -DGDK_COMPILATION
 
 LDADDS = $(GDK_DEP_LIBS)
index a00118eae728e7b2b6e659cebb75fa639f06820c..5930f7e7e4df8a057e5d489728040bb7a1660b23 100644 (file)
@@ -4,13 +4,14 @@ include $(top_srcdir)/Makefile.decl
 libgdkincludedir = $(includedir)/gtk-3.0/gdk
 libgdkx11includedir = $(includedir)/gtk-3.0/gdk/x11
 
-AM_CPPFLAGS =                  \
-       -DG_LOG_DOMAIN=\"Gdk\"  \
-       -DGDK_COMPILATION       \
-       -I$(top_srcdir)         \
-       -I$(top_srcdir)/gdk     \
-       -I$(top_builddir)/gdk   \
-       $(GTK_DEBUG_FLAGS)      \
+AM_CPPFLAGS =                          \
+       -DG_LOG_DOMAIN=\"Gdk\"          \
+       -DGDK_COMPILATION               \
+       -I$(top_srcdir)                 \
+       -I$(top_srcdir)/gdk             \
+       -I$(top_builddir)/gdk           \
+       $(GDK_HIDDEN_VISIBILITY_CFLAGS) \
+       $(GTK_DEBUG_FLAGS)              \
        $(GDK_DEP_CFLAGS)
 
 LDADDS = $(GDK_DEP_LIBS)